草庐IT

python - 同步与异步

全部标签

javascript - 使 FB.api() 调用同步

我正在FBjavascriptSDK之上创建fQueryAPI。到目前为止一切正常,但我现在卡在FB.api调用中了。实际上,我正在尝试使用FB.api函数加载facebook用户对象,即“/me”。functionsomefunc(){varr=fQuery.load(selector);//selector="me"returnr;}fQuery.load=function(selector){fQuery.fn.response="";returnFB.api("/"+selector,function(response){//wegetresponsehere.});}是否可以

javascript - 如何等待异步方法的回调返回值?

我知道等待一个异步方法是愚蠢的,oneshouldusecallbacksinstead.但是,如果第三方API强制您同步怎么办?我正在开发一个Chrome扩展程序,它将阻止用户访问已在另一个选项卡中打开的网站。我基本上需要根据打开的选项卡中的url取消请求。我想用chrome.webRequest.onBeforeRequest像这样:functiononBeforeRequest(details){varwebsiteAlreadyOpenInOtherTab;//Hereiwanttoset`websiteAlreadyOpenInOtherTab`byusingthe`chro

javascript - DOM 渲染是否保证在单个(同步)函数执行期间阻塞?

DOM阻塞是许多不熟悉JavaScript严格的单线程同步执行模型的人发现的困难方法,它通常只是我们想以某种方式解决的问题(使用超时、网络worker等)。一切都很好。但是,我想知道阻止实际的用户可见渲染是否是您实际上可以依赖的东西。我有90%的把握事实上在大多数浏览器中都是这种情况,但我希望这不仅仅是一个愉快一致的意外。我似乎无法从DOM规范甚至MDM等vendor文档中找到任何明确的声明。让我有点担心的是,虽然从页面上看确实看不到DOM的变化,但内部DOM几何结构(包括CSS转换和过滤器)确实在同步执行期间实际上更新了。例如:console.log(element.getBound

javascript - 如何跨 Chrome 实例同步 localStorage(或使用 chrome.storage.sync 而不使用已发布的扩展程序)?

这是我的情况:我写了一些Chrome用户脚本供我个人使用。以前,我只有一台机器,上面有一个Chrome实例,所以我非常乐意将任何持久数据转储到localStorage中。但是,我现在有多台机器,并且想在所有机器上的Chrome上使用我的用户脚本,同时使用我的持久数据。同步userscript代码本身很简单,但有点乏味(将它放在Bitbucket存储库中,然后拉取并手动安装),但我不知道如何跨机器同步我的localStorage数据。我考虑过将我的用户脚本转换为适当的Chrome扩展程序并使用chrome.storageAPI(使用chrome.storage.sync存储的数据显然可以

javascript - 如何在 Gulp 4 中使用异步/等待?

我正在尝试做这样的事情:gulp.task("test",async()=>{returngulp.src("**/*.scss").pipe(print((filePath)=>`File:${filePath}`));});(打印为gulp-print)但它给出了以下内容:[22:08:43]Starting'test'...[22:08:43]Finished'test'after12ms[22:08:43]File:src\app\styles\app.scss[22:08:43]File:src\app\styles\test.scss即它在打印消息之前完成。我正在使用Gul

javascript - Typescript/ES7 中异步/等待的有限并行性

我一直在尝试使用Typescript,但我现在对如何有效使用async/await有点困惑。我正在向数据库中插入一堆记录,我需要获取每次插入返回的ID列表。下面的简化示例一般有效,但它并不像我想要的那样优雅,而且它完全是顺序的。asyncfunctiongeneratePersons(){constnames=generateNames(firstNames,lastNames);letids=[]for(letnameofnames){constid=awaitdb("persons").insert({first_name:name.firstName,last_name:name

javascript - 异步函数返回 Promise { <pending> }?

我有以下异步函数:asyncfunctionreadFile(){letcontent=awaitnewPromise((resolve,reject)=>{fs.readFile('./file.txt',function(err,content){if(err){returnreject(err)}resolve(content)})})console.log(content)}readFile()这运行得很好。它按预期将文件缓冲区输出到控制台。但是现在,如果我尝试返回值:asyncfunctionreadFile(){letcontent=awaitnewPromise((res

javascript - 动态创建异步函数

我想知道是否可以像这样动态创建一个异步函数:newFunction('awaitPromise.resolve()');预期,前面的代码抛出:UncaughtSyntaxError:awaitisonlyvalidinasyncfunction 最佳答案 是的,您可以获得对非全局的引用AsyncFunction动态创建异步函数的构造函数。您可以像这样获得对AsyncFunction构造函数的引用:constAsyncFunction=Object.getPrototypeOf(asyncfunction(){}).construct

Javascript 如何通过解构将 promise.spread 语法迁移到异步/等待

我正在清理一些sequelize代码,findOrCreate函数返回一个需要展开才能获得实际结果对象的promise。我想重写我的代码以使用await代替,并且鉴于ES6支持数组解构,我认为用它代替User.findOrCreate({where:{mcId},defaults}).spread((user,created)=>{//dostuff})我能做到const[user,created]=awaitUser.findOrCreate({where:{mcId},defaults})但事实并非如此。我收到错误(intermediatevalue)isnotiterable执行

javascript - 解释 Google Analytics 异步跟踪器

我知道谷歌的异步分析跟踪器是如何工作的。以下代码用于初始化命令数组:var_gaq=_gaq||[];_gaq.push(['_setAccount','UA-xxxxxxxx-x'],['_trackPageview']);现在,这是一个标准数组,一旦加载了GA的代码就会被替换,并用作一种存储您的点击的队列。我的困惑在于想知道如果用户单击导致重新加载的链接(在加载GAjavascript之前),这些点击如何可能会持续存在。如果GA代码没有捕获到对_gaq对象的推送,那么用户单击一个链接并转到一个新页面,这个数组每次都只是重新初始化,不是吗?javascript变量不会在导致刷新的请求